| 1              | CLAIMS                                                                                      |  |
|----------------|---------------------------------------------------------------------------------------------|--|
| 2              |                                                                                             |  |
| 3              | 1. A method including concurrently performing a plurality of memory                         |  |
| 4              | lookups in response to a sequence of inputs each having information;                        |  |
| 5              | each one of said memory lookups being performed in response to a corre-                     |  |
| 6              | sponding distinct one of said inputs;                                                       |  |
| 7              | each one of said memory lookups being performed at a corresponding                          |  |
| 8              | memory;                                                                                     |  |
| 9              | whereby each one of said sequence of inputs has a memory lookup per-                        |  |
| 10<br>1010     |                                                                                             |  |
| 111            |                                                                                             |  |
| 12             | 2. A method as in claim 1, including substantially concurrently pro-                        |  |
| =<br>1313      | viding results responsive to a plurality of said inputs accessing different subsequences of |  |
| 14             | said memories.                                                                              |  |
| 13<br>14<br>14 |                                                                                             |  |
| 16             | 3. A method as in claim 1, wherein at least some inputs have their in-                      |  |
| 17             | formation applied to all said memories at least once, and to at least some of said memo-    |  |
| 18             | ries at least twice.                                                                        |  |
| 19             |                                                                                             |  |
| 20             | 4. A method as in claim 1, wherein each one of said memory lookups is                       |  |
| 21             | performed in response to a portion of said information.                                     |  |
| 22             |                                                                                             |  |

| 1  | 5.                    | A method as in claim 1, wherein each said input has substantially    |
|----|-----------------------|----------------------------------------------------------------------|
| 2  | equal amounts of sa   | aid information.                                                     |
| 3  |                       |                                                                      |
| 4  | 6.                    | A method as in claim 1, wherein said memory lookups are each sub-    |
| 5  | stantially performe   | d on a single monolithic integrated circuit.                         |
| 6  |                       |                                                                      |
| 7  | 7.                    | A method as in claim 1, wherein said sequence of inputs includes at  |
| 8  | least one of: a desti | ination IP address, an IP address, packet header information.        |
| 9  |                       |                                                                      |
| 10 | 8.                    | A method as in claim 1, wherein said corresponding memories col-     |
| 1  | lectively include le  | ookup results including at least one datum responsive to each one of |
| 12 | said inputs.          |                                                                      |
| 13 |                       |                                                                      |
| 14 | 9.                    | A method as in claim 8, wherein said lookup results collectively in- |
| 15 | clude packet forwa    | arding information.                                                  |
| 16 |                       |                                                                      |
| 17 | 10.                   | A method as in claim 1, wherein said memory lookup includes a se-    |
| 18 | quence of individ     | ual memory accesses, each said individual memory access being per-   |
| 19 | formed at one of s    | aid memories.                                                        |
| 20 |                       |                                                                      |
|    |                       |                                                                      |

| 1  | 11.                  | A method as in claim 10, including substantially concurrently pro-       |
|----|----------------------|--------------------------------------------------------------------------|
| 2  | viding results respo | onsive to a plurality of said inputs accessing different subsequences of |
| 3  | said memories.       |                                                                          |
| 4  |                      |                                                                          |
| 5  | 12.                  | A method as in claim 10, wherein at least some inputs have their in-     |
| 6  | formation applied t  | to all said memories at least once, and to at least some of said memo-   |
| 7  | ries at least twice. |                                                                          |
| 8  |                      |                                                                          |
| 9  | 13.                  | A method as in claim 10, wherein each said input has substantially       |
| 10 | equal amounts of sa  | aid information.                                                         |
| 11 |                      |                                                                          |
| 12 | 14.                  | A method as in claim 10, wherein said sequence of individual mem-        |
| 13 | ory accesses includ  | les one said individual memory access at each said memory.               |
| 14 |                      |                                                                          |
| 15 | 15.                  | A method as in claim 10, wherein said sequence of individual mem-        |
| 16 | ory accesses include | des one said individual memory access at each said memory, followed      |
| 17 | by a second individ  | dual memory access at each said memory for at least a subsequence of     |
| 18 | said memories.       |                                                                          |
| 19 |                      |                                                                          |
| 20 | 16.                  | A method as in claim 10, wherein said sequence of individual mem-        |
| 21 | ory accesses include | des one said individual memory access at each said memory for only a     |
| 22 | subsequence of sai   | d memories.                                                              |

first after the continues of the continu

| _ |
|---|
| 1 |
|   |
|   |
|   |

7

8

13 14 15

| 2 | 17.          | A method | including |
|---|--------------|----------|-----------|
| _ | <b>-</b> / • |          |           |

coupling each one of a sequence of inputs to a sequence of memories, said sequence having a last memory and a next memory corresponding to each said memory other than said last memory, wherein each said memory is responsive to a distinct portion of said information;

coupling a result from each said memory other than said last memory to its corresponding said next memory in said sequence; and

providing an output of at least one of said memories;

whereby said sequence of inputs is each coupled to said sequence of memories in a pipelined manner to provide said output at a rate substantially equaling one output as each input is received.

18. A method as in claim 17, including substantially concurrently providing results responsive to a plurality of said inputs accessing different subsequences of said memories.

17

18

19

20

16

19. A method as in claim 17, wherein at least some inputs have their information applied to all said memories at least once, and to at least some of said memories at least twice.

21

| 1                                              | 20. A metho                                                     | d as in claim 17, wherein each said input has substantially                                                                  |
|------------------------------------------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 2                                              | equal amounts of said inform                                    | ation.                                                                                                                       |
| 3                                              |                                                                 |                                                                                                                              |
| 4                                              | 21. A metho                                                     | d as in claim 17, wherein said sequence of inputs includes at                                                                |
| 5                                              | least one of: a destination IP                                  | address, an IP address, packet header information.                                                                           |
| 6                                              |                                                                 |                                                                                                                              |
| 7                                              | 22. A metho                                                     | od as in claim 17, wherein said sequence of memories are                                                                     |
| 8                                              | substantially included in a sin                                 | ngle monolithic integrated circuit.                                                                                          |
| 9                                              |                                                                 |                                                                                                                              |
| 10<br>1010                                     | 23. A metho                                                     | od as in claim 17, wherein said output is responsive to a se-                                                                |
| 9 10 10 11 11 11 12 12 12 12 12 12 12 12 12 12 | quence of individual memor                                      | y accesses, each said individual memory access being per-                                                                    |
|                                                |                                                                 | ies.                                                                                                                         |
| <b>31</b>                                      |                                                                 |                                                                                                                              |
| 13                                             |                                                                 |                                                                                                                              |
| 13                                             | 24. A metho                                                     | od as in claim 23, wherein at least some inputs have their in-                                                               |
| 13<br>14<br>14<br>15                           | 24. A method formation applied to all said                      | od as in claim 23, wherein at least some inputs have their in-<br>memories at least once, and to at least some of said memo- |
| 13<br>14<br>15<br>16                           |                                                                 |                                                                                                                              |
|                                                | ries at least twice.                                            |                                                                                                                              |
| 16                                             | ries at least twice.                                            |                                                                                                                              |
| 16<br>17                                       | ries at least twice.  25. A meth                                | memories at least once, and to at least some of said memo-                                                                   |
| 16<br>17<br>18                                 | ries at least twice.  25. A method ory accesses includes one sa | memories at least once, and to at least some of said memo-<br>od as in claim 23, wherein said sequence of individual mem-    |
| 16<br>17<br>18<br>19                           | ries at least twice.  25. A methodory accesses includes one sa  | memories at least once, and to at least some of said memo-<br>od as in claim 23, wherein said sequence of individual mem-    |

| 1                                          | by a second individual memory access at each said memory for at least a subsequence of    |  |
|--------------------------------------------|-------------------------------------------------------------------------------------------|--|
| 2                                          | said memories.                                                                            |  |
| 3                                          |                                                                                           |  |
| 4                                          | 27. A method as in claim 23, wherein said sequence of individual mem-                     |  |
| 5                                          | ory accesses includes one said individual memory access at each said memory for only a    |  |
| 6                                          | subsequence of said memories.                                                             |  |
| 7                                          |                                                                                           |  |
| 8                                          | 28. A method as in claim 17, wherein said sequence of memories col-                       |  |
| 9                                          | lectively include lookup results including at least one datum responsive to each one of   |  |
| 110 mg | said inputs.                                                                              |  |
| *411<br>*411                               |                                                                                           |  |
| 12                                         | 29. A method as in claim 28, wherein said lookup results collectively in-                 |  |
| 13<br>13                                   | clude a set of packet forwarding information.                                             |  |
| 13                                         |                                                                                           |  |
| 15                                         | 30. Apparatus including a circuit integrated onto a monolithic semicon-                   |  |
| 16                                         | ductor chip, said circuit including                                                       |  |
| 17                                         | a sequence of registers each having a portion of a corresponding lookup                   |  |
| 18                                         | search key in a sequence of said lookup search keys, each said register coupled to a cor- |  |
| 19                                         | responding one of a sequence of on-chip memories;                                         |  |
| 20                                         | a subsequence of said memories not including a last said memory each                      |  |
| 21                                         | having an output register associated therewith, said output register being coupled to an  |  |
| 22                                         | associated next said memory for each said memory in said subsequence;                     |  |

| 1  | a plurality of said memories capable of operating substantially concurrently              |
|----|-------------------------------------------------------------------------------------------|
| 2  | each on a portion of a corresponding plurality of said lookup search keys;                |
| 3  | whereby said sequence of registers is capable of coupling each lookup                     |
| 4  | search key in portions to said sequence of memories, each said memory being responsive    |
| 5  | to each said lookup search key in sequence, each said lookup search key being coupled to  |
| 6  | each said memory in sequence.                                                             |
| 7  |                                                                                           |
| 8  | 31. Apparatus as in claim 30, including an output register associated                     |
| 9  | with said last memory and coupled to an output of said apparatus.                         |
| 0  |                                                                                           |
| 1  | 32. Apparatus as in claim 30, including an output register associated                     |
| 12 | with said last memory, said output register being coupled to an associated earlier memory |
| 13 | in said sequence.                                                                         |
| 14 |                                                                                           |
| 15 | 33. Apparatus as in claim 30, wherein a plurality of output registers as-                 |
| 16 | sociated with different memories are each coupled to an output for said circuit.          |
| 17 |                                                                                           |
| 18 | 34. Apparatus as in claim 30, wherein an output register associated with                  |
| 19 | a memory other than said last memory is coupled to an output for said circuit.            |
| 20 |                                                                                           |
| 21 | 35. Apparatus as in claim 30, wherein said lookup search key includes at                  |
| 22 | least one of: a destination IP address, an IP address, packet header information.         |

| 1       |                                                                                             |
|---------|---------------------------------------------------------------------------------------------|
| 2       | 36. Apparatus as in claim 30, wherein said memories collectively in-                        |
| 3       | clude lookup results including at least one datum responsive to each one of said inputs.    |
| 4       |                                                                                             |
| 5       | 37. Apparatus as in claim 36, wherein said lookup results collectively                      |
| 6       | include packet forwarding information.                                                      |
| 7       |                                                                                             |
| 8       | 38. Apparatus including                                                                     |
| 9       | a sequence of memories, said sequence having a last memory and a next                       |
| 9<br>10 | memory corresponding to each said memory other than said last memory, each said             |
| 11      | memory being coupled to a distinct portion of one of a sequence of lookup search keys;      |
| 12      | each said memory other than said last memory being coupled to its corre-                    |
| 13      | sponding said next memory in said sequence; and                                             |
| 14      | whereby said sequence of inputs is each coupled to said sequence of memo-                   |
| 15      | ries in a pipelined manner to provide said output at a rate substantially equaling one out- |
| 16      | put as each input is received.                                                              |
| 17      |                                                                                             |
| 18      | 39. Apparatus as in claim 38, wherein a plurality of output registers as-                   |
| 19      | sociated with different memories are each coupled to an output for said circuit.            |
| 20      |                                                                                             |
| 21      | 40. Apparatus as in claim 38, wherein an output register associated with                    |

22

a memory other than said last memory is coupled to an output for said circuit.

| 1 |
|---|
|   |
| - |

2 41. Apparatus as in claim 38, wherein said last memory is coupled to an associated earlier memory in said sequence.

4

5 42. Apparatus as in claim 38, wherein said sequence of lookup search 6 keys includes at least one of: a destination IP address, an IP address, packet header information.

8

43. Apparatus as in claim 38, wherein said sequence of memories collectively include lookup results including at least one datum responsive to each one of said lookup search keys.

44. Apparatus as in claim 43, wherein said lookup results collectively include a set of packet forwarding information.